<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        /*
        初始化
        */
        body {
            width: 70%;
            max-width: 960px;
            margin: 20px auto;
        }

        button {
            font-size: 18px;
            line-height: 1.5;
            width: 15%;
        }

        #d1{
            height: 100%;
            display: flex;
            align-items: center;
            justify-content: center;
        }

        div {
            height: 100px;
            border: 1px solid black;
            display: flex;
        }
        /*
        flex的定位
         */
        .d1{

            /*

            flex-start 或 flex-end 这样使 flex 项在交叉轴的开始或结束处对齐所有的值
            元素垂直
            flex-start    居顶
            center  居中
            flex-end 居底
            */
            align-items: self-start;
            /*
            默认值是 flex-start，这会使所有 flex 项都位于主轴的开始处。
                    flex-end 来让 flex 项到结尾处。
                   space-between，它和 space-around 非常相似，只是它不会在两端留下任何空间。
            元素水平
            flex-start 左边
            center  居中
            flex-end 右边
            space-between 两端对齐
            */
            justify-content:center ;
        }
    .d2 button{
        /* 给子元素设置水平距离*/
        align-self: flex-end;
    }


    </style>
</head>
<body>
    <div id='d1'>
        <img src="/img/flex-img.png">
    </div>
    <div class="d1">
        <button>Smile</button>
        <button>Laugh</button>
        <button>Wink</button>
        <button>Shrug</button>
        <button>Blush</button>
    </div>
    <div class="d2">
        <button>Smile</button>
        <button>Laugh</button>
        <button>Wink</button>
        <button>Shrug</button>
        <button>Blush</button>
    </div>



</body>
</html>